Scheduler system and method thereof

ABSTRACT

Disclosed is a method and system based on MAC frames for enabling a QAP to seamlessly operate between granting polls for upstream and sidestream traffic while sending downstream frames. The inventive scheduling method uses a minimum set of mandatory TSPEC parameters to generate a schedule, which provides minimum performance requirement in wireless local area networks (WLANs).

BACKGROUND OF THE INVENTION

1. Field of the Invention

The present invention relates generally to communication systems, and more particularly, the present invention relates to a scheduler and related method for efficiently granting polls to upstream and/or sidestream traffic and sending downstream frames.

2. Description of the Related Art

Scheduling is essential in providing quality of service (QoS) in data networks where multiple users share common resources. This is especially true in the context of wireless links. That is, the time-varying nature of wireless links presents great challenges in the design of scheduling policy in wireless data services because of the scarcity of radio resource and the time-varying nature of radio quality. Currently, most scheduling policies are dependent on the queue length or arrival rate or time stamps present in a transmitted medium access control (MAC) frame and do not consider the channel capacity. This would suffice if the channel capacity to all users were constant as is the case in wire-line systems. However, in the context of wireless networks, a drawback of these schemes is that they always result in an under-utilization of the wireless resources by not accounting for the channel capacity (i.e., the channel condition and continuously varying transmission rate).

Currently, the 802.11 MAC offers a simplified model, referred to as a “best-effort” model. In the simplified scheme, all frames receive the same level of service with no distinction for frames from different applications. In accordance with the model, an attempt is made to forward frames as soon as possible, but makes no quantitative commitments about the quality of service (QoS) provisioning. But with the advent of 802.11e, which is a quality of service MAC, a scheduler is needed to guarantee the QoS requirements for different streams.

Accordingly, there is a need for a scheduling policy that can be incorporated on top of the IEEE 802.11e/D4.0. draft standard enabling an QoS access point (QAP) to take into account the QoS requirements of the stream and schedule appropriately.

SUMMARY OF THE INVENTION

The present invention is directed to a scheduling method for use in a wireless local area network (WLAN) that enables a QAP to seamlessly operate between granting polls for upstream and sidestream traffic while sending downstream frames.

According to an aspect of the invention, there is provided a scheduling method for scheduling the transmission of a data stream in a wireless communications network having at least one access point (QAP) and at least one station (WSTA). The method is achieved by receiving a request to send at least one data stream for transmission from at least one WSTA by the QAP; granting, by the QAP, the request to send the data stream; transmitting, by the WSTA, a MAC frame comprised of a set of parameters defining the characteristics of the data stream; and, calculating, by the QAP, service and transmission times according to a schedule algorithm for servicing at least one WSTA. The schedule algorithm is operative to schedule the transmission of at least one data stream at the calculated service and transmission times, and the parameters of the MAC frame includes: Mean Data Rate (ρ_(i)), Nominal MSDU Size (L_(i)), Maximum Service Interval or Delay Bound (D_(i)), Transmission Rate (R_(i)), Size of Maximum MSDU (M_(i)).

According to another aspect of the invention, a system for scheduling the transmission of a data stream in a wireless communications network, which includes at least one access point (QAP) and at least one station (WSTA). The system includes means for determining, at the QAP, whether at least one data stream is originated from at least one WSTA based on a MAC frame comprised of a set of parameters defining the characteristics of at least one data stream; means for computing service and transmission times, at the QAP, for servicing at least one WSTA in accordance with a schedule algorithm; and, means for transmitting, by the WSTA, at least one data stream at the computed service and transmission times. The means for calculating the service and transmission times further comprises means for determining a Service Interval (SI) and a TXOP duration for said SI, wherein the SI is determined by selecting a number that is lower than the SI and is a submultiple of a beacon interval.

BRIEF DESCRIPTION OF THE DRAWINGS

A more complete understanding of the method and apparatus of the present invention may be had by reference to the following detailed description when taken in conjunction with the accompanying drawings wherein:

FIG. 1 illustrates the architecture of a wireless communication system whereto embodiments of the present invention are to be applied;

FIG. 2 is a block diagram of a QAP according to an embodiment of the invention;

FIG. 3 illustrates a format of the Traffic Specification (TSPEC) elements containing a set of parameters that define the characteristics and QoS expectations of a traffic stream; and

FIGS. 4-6 illustrate a timing diagram to explain the polling procedure according to an embodiment of the invention.

DETAILED DESCRIPTION OF THE EMBODIMENTS

In the following description, for purposes of explanation rather than limitation, specific details are set forth such as the particular architecture, interfaces, techniques, etc., in order to provide a thorough understanding of the present invention. For purposes of simplicity and clarity, detailed descriptions of well-known devices, circuits, and methods are omitted so as not to obscure the description of the present invention with unnecessary detail.

The inventive method is a scheduling algorithm that provides minimum performance requirement for upstream, downstream and sidestream scheduling in wireless local area networks (WLANs). The method is intended for implementation by an access point (QAP) in a QBSS network.

FIG. 1 is an illustration of a representative network 100 whereto embodiments of the present invention may be applied. As shown, FIG. 1 illustrates a QBSS network 100 including an QAP 103 coupled to a stationary network 111 and a plurality of stations (WSTA₁ through WSTA₃) 110, 112, 114. A primary function of the QAP 103 is to facilitate the transmission of data packets. Data packets include “upstream” packets (i.e., packets transmitted in a direction from the WSTAs 110-114 to the QAP 103), labeled as “U”, “downstream” packets (i.e., packets transmitted in a direction from the QAP 103 to the WSTAs 110-114), labeled as “D”, and “sidestream” packets (i.e., packets transmitted from one WSTA 110-114 to another WSTA), labeled as “S”. Although a limited number of WSTAs is shown in FIG. 1 for illustrative purposes, it is to be understood that the WLAN can support concurrent communications between a much larger number of WSTAs. Thus, the number of WSTAs in the drawing should not impose limitations on the scope of the invention.

Referring to FIG. 2, a block diagram of the functional elements of the QAP 103 of FIG. 1 is shown. The QAP 103 includes a scheduler 105 for determining, first the time instants when the QAP 103 is required to serve the WSTAs for upstream sidestream and/or downlink traffic, and second, the servicing times (or TXOP) to serve each WSTA 110-114 desiring to transmit traffic so as to satisfy the WSTA's 110-114 pre-negotiated data rates and other QoS requirements. The QAP 103 further includes an admissions control unit 350 for determining if traffic from a WSTA 110-114 can be admitted in the QBSS and if its QoS requirements can be satisfied depending on the available bandwidth.

The present invention is directed exclusively to the scheduling of parameterized QoS traffic. As defined by the IEEE 802.11 standard, parameterized traffic is identified by priority values in the range 8 to 15 which are included as part of a 16 bit QoS control field in the MAC header of each frame. The priority values 8-15 are interpreted as traffic stream identifiers (TSID). Parameterized traffic could include, for example, video telephone, low cost video conferencing, imaging, High Definition Television (HDTV), streaming audio and/or video and so on. Each of the afore-mentioned applications may place different demands on the wireless communications network 100 depending upon their respective bandwidth requirements. That is, some applications described above are more bit intensive than others (e.g., an HDTV video stream at 24 Mbps). In general, most real time applications qualify as being bit intensive and as such place high demands on the transmission network 100. Other applications, such as stereophonic audio which is typically transmitted at 128 Kbps is comparably less bit intensive and consequently less demanding on the network 100 resources. Therefore, a mechanism is needed to efficiently schedule these disparate network demands for processing by the network 100.

To perform scheduling in an efficient manner at the QAP 103, the scheduler 105 must control two processes: (1) determine the existence of any upstream or sidestream streams that the WSTAs 110-114 intend to transmit (2) determine if there is data required to be sent downstream from the stationary network 111, via the QAP 103, to the WSTAs 110-114. The first process is achieved in a polling operation performed by the scheduler 105 at the QAP 103. In the polling operation, the scheduler 105 determines which WSTAs have traffic streams to be transmitted upstream to the QAP 103 or sidestream to other WSTA 110-114.

Once it is determined by the scheduler 105 that one or more WSTAs 110-114 have traffic streams to be transmitted/received, a negotiation session is conducted between the QAP 103 and the one or more WSTAs 110-114 intending to transmit data upstream or sidestream.

As part of the negotiation session, a permission protocol is invoked by the Admission Control Unit 109 in the QAP 103 to grant permission to the requesting WSTA. Once permission is granted to an WSTA, the negotiation process then proceeds by the requesting WSTA, which has been granted permission, informing the QAP 103 of certain parameters related to the traffic stream to be transmitted, including the data rate and other traffic QoS characteristics. Upon receiving these parameters at the QAP 103, the scheduler 105 associated with the QAP 103 collects the parameter data for each traffic stream (i.e., requesting WSTA) compute in advance a time instance for servicing the various WSTAs requesting to transmit data upstream, downstream or sidestream, in a manner that satisfies a pre-negotiated data rate and other QoS requirements.

Now, a detailed description of the embodiment of the present invention relating to operation steps of the scheduler is described hereinafter.

In operation, each WSTA send a MAC frame (or Traffic Specification (TSPEC) frame), which contains information needed by QAP for proper operation of the QoS facility. The format of the TSPEC frame as set forth in IEEE 802.11e is defined in FIG. 3. As shown, the TSPEC contains the set of parameters that define the characteristics and QoS expectation of a traffic stream for use by the QAP and non-QAP WSTAs in support of parameterized QoS traffic transfer. A key feature of the scheduling method of the invention is that the inventive simplified scheduling method uses a minimum set of mandatory TSPEC parameters to generate a schedule.

Referring to FIG. 3, the scheduler 105 uses a mandatory set of TSPEC parameters as set forth under this invention to generate a TXOP duration and service interval: (1) Mean Data Rate (ρ), (2) Nominal MSDU Size (L), and (3) Maximum Service Interval or Delay Bound (D). The scheduler 105 also uses other parameters available to generate a TXOP duration and service interval: (i) Minimum PHY Rate (R), (ii) MSDU of Maximum Size, M=2304bytes, and (iii) Overheads In Time units (O). In the preferred embodiment, the schedule for a stream is calculated in two steps. The first step is the calculation of the Scheduled Service Interval (SI). In the second step, the TXOP duration for a given SI is calculated for the stream.

It is noted that the basic unit of allocation of the right to transmit onto the WSTA is the TXOP. Each TXOP is defined by an implicit starting time (relative to the end of a preceding frame) and a defined maximum length. Thus, TXOP is the complete time spent for transmission from one station or the polling times to poll each WSTA 110-114 desiring to transmit data stream.

Admission Control Process

First the QAP needs to decide if the stream for a particular WSTA can be admitted for transmission. In this regard, the number of frames (N) that arrive during Maximum Service Interval or Delay (D) is calculated as follows: N _(i) =D _(i)ρ_(i) /L _(i)

Then, TXOP_(i) allocated to this stream in D is calculated as follows:

TXOP_(i)=N_(i) L_(i)/R_(i)+O, where O represents the overheads in time units.

Using the above data, it is determined whether a particular stream is admitted. A stream is admitted if it satisfies the following equation, otherwise rejected by QAP: ${{{{TXOP}_{i + 1}/D_{i + 1}} + {\sum\limits_{i = 1}^{k}\quad{{TXOP}_{i}/D_{i}}}} \leq 1},$

Where i+1 stands for the newly arriving stream and the summation index counts for the streams already admitted and undergoing service from the QAP.

If the stream is admitted, then the scheduler 105 proceeds to the calculation of SI and TXOP duration as follows:

Calculation of Service Interval (SI)

The calculation of the Scheduled Service Interval is done as follows. First the scheduler calculates the minimum of all Maximum Service Intervals (or Delay Bounds) for all admitted streams. Here, this minimum be “m”. Second, the scheduler chooses a number lower than “m” that it is a submultiple of the beacon interval. This value will be the Scheduled Service Interval for all WSTAs with admitted streams.

For example, if three streams with maximum service intervals=60, 65, and 70 ms, an the beacon interval is 100 ms, then choose a Service Interval (SI)=50 ms.

Calculation of TXOP Duration

For the calculation of the TXOP duration for an admitted stream, the scheduler 105 uses the following parameters: Mean Data Rate (ρ) and Nominal MSDU Size (L) from the negotiated TSPEC, the Scheduled Service Interval (SI) calculated above, Physical Transmission Rate (R), Size of Maximum MSDU, i.e., 2304 bytes (M) and Overheads in time units (O). Note that the Physical Transmission Rate can be the Minimum PHY Rate negotiated in the TSPEC. If Minimum PHY Rate is not committed in AddTS response frame, the scheduler can use observed PHY rate as R. It is assumed in the embodiment that the Overheads in time include interframe spaces, ACKs and CF-Polls. For simplicity, details for the overhead calculations are omitted in this example.

Now, the TXOP duration is calculated as follows. First the scheduler calculates the number of MSDUs that arrived at the Mean Data Rate during the SI. This number is N: $N_{i} = \left\lceil \frac{{SI} \times \rho_{i}}{L_{i}} \right\rceil$

Then the scheduler calculates the TXOP duration as the maximum of (1) time to transmit Ni frames at Ri and (2) time to transmit one maximum size MSDU at Ri (plus overheads): ${TXOP}_{i} = {\max\left( {{\frac{N_{i} \times L_{i}}{R_{i}} + O},{\frac{M}{R_{i}} + O}} \right)}$

An example is shown in FIG. 4. Stream from QSTA “i” is admitted. The beacon interval is 100 ms and the Maximum Service Interval for the stream is 60 ms. The scheduler calculates a Scheduled Service Interval (SI) equal to 50 ms using the steps explained above.

The same process is repeated continuously while the Maximum Service Interval for the admitted stream is smaller than current SI. An example is shown in FIG. 5.

If a new stream is admitted with a Maximum Service Interval smaller than the current SI, the scheduler needs to change the current SI to a smaller number than the Maximum Service Interval of the newly admitted stream. Therefore the TXOP duration for the current admitted streams needs also to be recalculated with the new SI.

If a stream is dropped, the scheduler may use the time available to resume contention. The scheduler may also choose to move the TXOPs for the QSTAs following the QSTA dropped to use the unused time. An example is shown in FIG. 6 when stream for QSTA j is removed. However, this last option may require the announcement of a new schedule to all QSTAs.

Having thus described a preferred embodiment of a method for generating a scheduler with a minimum set of TSPEC parameters in a WLAN, it should be apparent to those skilled in the art that certain advantages of the system have been achieved. The foregoing is to be constructed as only being an illustrative embodiment of this invention. Persons skilled in the art can easily conceive of alternative arrangements providing a functionality similar to this embodiment without any deviation from the fundamental principles or the scope of this invention. 

1. A method for scheduling the transmission of a data stream in a wireless communications network having at least one access point (QAP) (103) and at least one station (WSTA) (110, 112, 114), the method comprising the steps of: receiving a request to send at least one data stream for transmission from at least one WSTA (110, 112, 114) by said QAP(103); granting, by said QAP(103), said request to send said at least one data stream; transmitting, by said at least one WSTA(110, 112, 114), a MAC frame comprised of a set of parameters defining the characteristics of said at least one data stream; and, calculating, by said QAP(103), service and transmission times according to a schedule algorithm for servicing said at least one WSTA(110, 112, 114).
 2. The method of claim 1, wherein said schedule algorithm is operative to schedule the transmission of said at least one data stream at said calculated service and transmission times.
 3. The method of claim 1, further comprising the step of generating, at said QAP(103), polling frames or downlink frames at said calculated service and transmission times allocated to said at least one WSTA(110, 112, 114) for transmission of said at least one data stream.
 4. The method of claim 1, wherein said at least one data stream is parameterized traffic stream.
 5. The method of claim 1, wherein the parameters of said MAC frame includes: Mean Data Rate (ρ_(i)), Nominal MSDU Size (L_(i)), and Maximum Service Interval or Delay Bound (D_(i)).
 6. The method of claim 1, wherein the step of calculating said service and transmission times comprises the steps of: determining a Service Interval (SI) and determining a TXOP duration for said SI.
 7. The method of claim 6, wherein the step of determining said SI comprises the steps of: selecting a number that is lower than said Maximum Service Intervals, and selecting a number that is lower than said calculated SI and is a submultiple of a beacon interval.
 8. The method of claim 6, wherein the step of determining said TXOP uses additional parameters: Transmission Rate (R_(i)), Size of Maximum MSDU (M_(i)), and Overheads in Time units (O_(i)).
 9. The method of claim 6, wherein the step of determining said TXOP duration comprises the step of: calculating the number of MSDUs (N_(i)) that arrived at said Mean Data Rate (ρ_(i)), during said SI according to the following equation: $N_{i} = \left\lceil \frac{{SI} \times \rho_{i}}{L_{i}} \right\rceil$ calculating said TXOP_(i) duration as a maximum of (i) time to transmit number of MSDUs (N_(i)) frames at said Transmission Rate (R_(i)), (ii) time to transmit one maximum size MSDU at said R_(i), and (iii) Overhead in time units (O) according to the following equation: ${TXOP}_{i} = {\max\left( {{\frac{N_{i} \times L_{i}}{R_{i}} + O},{\frac{M}{R_{i}} + O}} \right)}$
 10. The method of claim 5, wherein the step of calculating said service and transmission times are performed if an admission control condition is satisfied, as follows: ${{{{TXOP}_{i + 1}/D_{i + 1}} + {\sum\limits_{i = 1}^{k}\quad{{TXOP}_{i}/D_{i}}}} \leq 1},{{TXOP}_{i} = {{{N_{i}{L_{i}/R_{i}}} + {O\quad{and}\quad N_{i}}} = {D_{i}{\rho_{i}/L_{i.}}}}}$ where R_(i) represents a transmission Rate, N_(i) represents number of frames arriving during D_(i), and O represents overheads in time units.
 11. A method for scheduling the transmission of a data stream in a wireless communications network having at least one access point (QAP)(103) and at least one station (WSTA) (110, 112, 114), the method comprising the steps of: determining, at said QAP(103), whether at least one data stream is originated from said at least one WSTA(110, 112, 114) based on a MAC frame comprised of a set of parameters defining the characteristics of said at least one upstream sidestream or downstream traffic stream; computing service and transmission times, at said QAP(103), for servicing said at least one WSTA(110, 112, 114) in accordance with a schedule algorithm; and, transmitting, by said at least one WSTA(110, 112, 114), said at least one data stream at said computed service and transmission times.
 12. The method of claim 11, wherein said at least one data stream is parameterized traffic stream.
 13. The method of claim 11, wherein the parameters of said MAC frame includes: Mean Data Rate (ρ_(i)), Nominal MSDU Size (L_(i)), and Maximum Service Interval or Delay Bound (D_(i)).
 14. The method of claim 11, wherein the step of calculating said service and transmission times comprises the steps of: determining a Service Interval (SI) and determining a TXOP duration for said SI.
 15. The method of claim 14, wherein the step of determining said SI comprises the steps of: selecting a number that is lower than said Maximum Service Intervals, and selecting a number that is lower than said calculated SI and is a submultiple of a beacon interval.
 16. The method of claim 14, wherein the step of determining said TXOP uses additional parameters: Transmission Rate (R_(i)), Size of Maximum MSDU (M_(i)), and Overheads in Time units (O_(i)).
 17. The method of claim 14, wherein the step of determining said TXOP duration comprises the step of: calculating the number of MSDUs (N_(i)) that arrived at said Mean Data Rate (ρ_(i)), during said SI according to the following equation: $N_{i} = \left\lceil \frac{{SI} \times \rho_{i}}{L_{i}} \right\rceil$ calculating said TXOP_(i) duration as a maximum of (i) time to transmit number of MSDUs (N_(i)) frames at said Transmission Rate (R_(i)), (ii) time to transmit one maximum size MSDU at said R_(i), and (iii) Overheads in time units (O) according to the following equation: ${TXOP}_{i} = {\max\left( {{\frac{N_{i} \times L_{i}}{R_{i}} + O},{\frac{M}{R_{i}} + O}} \right)}$
 18. A system for seamlessly granting polls for upstream and/or sidestream traffic while simultaneously sending downstream traffic from said (AP)(103) to said at least one WSTA(110, 112, 114), the system comprising: a memory for storing a computer-readable code; and, a processor operatively coupled to said memory, said processor configured to: (1) receive a request to send at least one data stream for transmission from at least one WSTA(110, 112, 114) by said QAP(103); (2) grant said request to send said at least one data stream by said WSTA (110, 112, 114) or QAP(103); (3) transmit, by said at least one WSTA(110, 112, 114), a MAC frame comprised of a set of parameters defining the characteristics of said at least one data stream; and, (4) calculate, by said QAP(103), service and transmission times according to a schedule algorithm for servicing said at least one WSTA(110, 112, 114).
 19. The system of claim 19, wherein the parameters of said MAC frame includes: Mean Data Rate (ρ_(i)), Nominal MSDU Size (L_(i)), and Maximum Service Interval or Delay Bound (D_(i)).
 20. A system for scheduling the transmission of a data stream in a wireless communications network having at least one access point (QAP)(103) and at least one station (WSTA) (110, 112, 114), the system comprising: means for determining, at said QAP(103), whether at least one data stream is originated from said at least one WSTA(110, 112, 114) based on a MAC frame comprised of a set of parameters defining the characteristics of said at least one data stream; means for computing service and transmission times, at said QAP(103), for servicing said at least one WSTA(110, 112, 114) in accordance with a schedule algorithm; and, means for transmitting, by said at least one WSTA(110, 112, 114), said at least one data stream at said computed service and transmission times.
 21. The system of claim 20, wherein the parameters of said MAC frame includes: Mean Data Rate (ρ_(i)), Nominal MSDU Size (L_(i)), and Maximum Service Interval or Delay Bound (D_(i)).
 22. The system of claim 20, wherein the means for calculating said service and transmission times further comprises means for determining a Service Interval (SI) and a TXOP duration for said SI.
 23. The method of claim 22, wherein the step of determining said SI comprises the steps of: selecting a number that is lower than said Maximum Service Intervals, and selecting a number that is lower than said calculated SI and is a submultiple of the beacon interval.
 24. The system of claim 22, wherein the step of determining said TXOP uses additional parameters: Transmission Rate (R_(i)), Size of Maximum MSDU (M_(i)), and Overheads in Time units (O_(i)).
 25. The system of claim 24, wherein said TXOP duration is determined by: $N_{i} = \left\lceil \frac{{SI} \times \rho_{i}}{L_{i}} \right\rceil$ calculating the number of MSDUs (N_(i)) that arrived at said Mean Data Rate (ρ_(i)) during said SI according to the following equations: ${TXOP}_{i} = {\max\left( {{\frac{N_{i} \times L_{i}}{R_{i}} + O},{\frac{M}{R_{i}} + O}} \right)}$ calculating said TXOP_(i) duration as a maximum of time to transmit number of MSDUs (N_(i)) frames at said Transmission Rate (R_(i)), and time to transmit one maximum size MSDU at said R_(i), and Overheads in time units (O) according to the following equation: ${TXOP}_{i} = {\max\left( {{\frac{N_{i} \times L_{i}}{R_{i}} + O},{\frac{M}{R_{i}} + O}} \right)}$
 26. The system of claim 21, wherein the step of calculating said service and transmission times are performed if an admission control condition is satisfied, as follows: ${{{{TXOP}_{i + 1}/D_{i + 1}} + {\sum\limits_{i = 1}^{k}\quad{{TXOP}_{i}/{D_{i}.}}}} \leq 1},{{TXOP}_{i} = {{{N_{i}{L_{i}/R_{i}}} + {O\quad{and}\quad N_{i}}} = {D_{i}{\rho_{i}/{L_{i}.}}}}}$ where R_(i) represents a transmission Rate, N_(i) represents number of frames arriving during D_(i), and O represents overheads in time units. 